iT邦幫忙

1

Python - 統一發票爬蟲

Kun 2022-12-21 09:13:252646 瀏覽
  • 分享至 

  • xImage
  •  

於財政部統一發票網頁爬取開獎號碼,並可輸入獎號,對獎。
開發環境:google colab

import requests
url = 'https://invoice.etax.nat.gov.tw/index.html'
# 取得網頁html
web = requests.get(url)    
# 設置編碼,避免中文亂碼
web.encoding='utf-8'       

from bs4 import BeautifulSoup
# 轉換成標籤樹
tree = BeautifulSoup(web.text, "html.parser")  
# 取出開獎月份
issue = tree.select(".carousel-item")[0].getText(); 
print(issue)
# 取出中獎號碼陣列
winlist = tree.select('.container-fluid')[0].select('.etw-tbiggest')  
#特別獎
nss = winlist[0].getText()  
#特獎
ns = winlist[1].getText() 
# 頭獎
n1 = [winlist[2].getText()[-8:], winlist[3].getText()[-8:], winlist[4].getText()[-8:]] 
print("特別獎:\n" + "  "+nss + "\n")
print("特獎:\n"+"  " + ns + "\n")
print("頭獎:")
for j in n1:
  print("  "+j)
print("\n")
while True:
    try:
        # 對獎
        inputnum = input('輸入發票號碼:')
        if inputnum == nss: print('中 1000 萬元!')
        if inputnum == ns: print('中 200 萬元!')
        for i in n1:
            if inputnum == i:
                print('中 20 萬元!')
                break
            if inputnum[-7:] == i[-7:]:
                print('中 4 萬元!')
                break
            if inputnum[-6:] == i[-6:]:
                print('中 1 萬元!')
                break
            if inputnum[-5:] == i[-5:]:
                print('中 4000 元!')
                break
            if inputnum[-4:] == i[-4:]:
                print('中 1000 元!')
                break
            if inputnum[-3:] == i[-3:]:
                print('中 200 元!')
                break
    except:
      print("Error") 
      break


圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言